<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Manage Names List</title>
    <style>
        body {
            font-family: 'Arial', sans-serif;
            margin: 20px;
            color: #333;
            background-color: #eaeaea;
        }
        h1 {
            color: #004080;
            border-bottom: 2px solid #004080;
            padding-bottom: 10px;
            font-size: 24px;
        }
        form {
            background: #ffffff;
            padding: 20px;
            border-radius: 8px;
            box-shadow: 0 0 10px rgba(0,0,0,0.2);
            margin-bottom: 30px;
            border: 1px solid #cccccc;
        }
        label {
            display: block;
            font-weight: bold;
            margin-bottom: 8px;
            color: #333;
        }
        input[type="text"], input[type="number"], input[type="date"] {
            width: calc(100% - 22px);
            padding: 10px;
            border: 1px solid #cccccc;
            border-radius: 4px;
            box-sizing: border-box;
            margin-bottom: 12px;
            font-size: 16px;
        }
        button {
            background-color: #004080;
            color: #ffffff;
            border: none;
            padding: 10px 15px;
            border-radius: 4px;
            cursor: pointer;
            font-size: 16px;
            transition: background-color 0.3s;
        }
        button:hover {
            background-color: #003366;
        }
        .alert {
            background-color: #d4edda;
            color: #155724;
            border: 1px solid #c3e6cb;
            padding: 15px;
            border-radius: 4px;
            margin-top: 20px;
        }
        .error {
            background-color: #f8d7da;
            color: #721c24;
            border: 1px solid #f5c6cb;
        }
        .removed-names {
            margin-top: 20px;
            background-color: #ffffff;
            padding: 10px;
            border: 1px solid #cccccc;
            border-radius: 4px;
            box-shadow: 0 0 5px rgba(0,0,0,0.1);
        }
        .removed-names h2 {
            font-size: 18px;
            color: #004080;
            margin-top: 0;
        }
        .removed-names ul {
            list-style-type: disc;
            padding-left: 20px;
        }
    </style>
    <!-- Include jsPDF library -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/2.5.1/jspdf.umd.min.js"></script>
</head>
<body>
    <h1>Manage Names List</h1>

    <!-- Form to specify the starting name, number of names, and date -->
    <form id="displayForm">
        <label for="startName">Starting Name:</label>
        <input type="text" id="startName" name="startName" required>
        <label for="numNamesFirst">Number of Names for First Column:</label>
        <input type="number" id="numNamesFirst" name="numNamesFirst" min="1" required>
        <label for="numNamesThird">Number of Names for Third Column:</label>
        <input type="number" id="numNamesThird" name="numNamesThird" min="0" required>
        <label for="numNamesFourth">Number of Names for Fourth Column:</label>
        <input type="number" id="numNamesFourth" name="numNamesFourth" min="0" required>
        <label for="displayDate">Date:</label>
        <input type="date" id="displayDate" name="displayDate">
        <button type="submit">Download Names List as PDF</button>
    </form>

    <!-- Form to input a name to remove -->
    <form id="removeForm">
        <label for="removeName">Name to Remove:</label>
        <input type="text" id="removeName" name="removeName" required>
        <button type="submit">Remove Name</button>
    </form>

    <!-- Notifications container -->
    <div id="notificationContainer"></div>

    <!-- Section to display removed names -->
    <div class="removed-names">
        <h2>Removed Names</h2>
        <ul id="removedNamesList"></ul>
    </div>

    <script>
        const { jsPDF } = window.jspdf; // Get jsPDF from the global window object
        const displayForm = document.getElementById('displayForm');
        const removeForm = document.getElementById('removeForm');
        const notificationContainer = document.getElementById('notificationContainer');
        const removedNamesList = document.getElementById('removedNamesList');

        // Predefined list of names
        let predefinedNames = [
            "Alice", "Bob", "Charlie", "David", "Eve",
            "Frank", "Grace", "Hannah", "Ivy", "Jack",
            "Karen", "Leo", "Mona", "Nina", "Oscar",
            "Paul", "Quinn", "Rachel", "Steve", "Tom",
            "Uma", "Vera", "Will", "Xena", "Yara", "Zane",
            "Alice", "Bob", "Charlie", "David", "Eve",
            "Frank", "Grace", "Hannah", "Ivy", "Jack",
            "Karen", "Leo", "Mona", "Nina", "Oscar",
            "Paul", "Quinn", "Rachel", "Steve", "Tom",
            "Uma", "Vera", "Will", "Xena", "Yara", "Zane"
        ];

        // Track removed names
        let removedNames = [];

        // Function to generate PDF content
        function generatePDFContent(startName, countFirst, countThird, countFourth, displayDate) {
            const pdf = new jsPDF();
            pdf.setFontSize(16);
            pdf.text('Names List', 20, 20);

            if (displayDate) {
                pdf.setFontSize(12);
                pdf.text(`Date: ${displayDate}`, 20, 30);
            }

            const marginLeft = 20;
            const marginMiddle1 = 100;
            const marginMiddle2 = 160;
            const marginRight = 220;
            const lineHeight = 10;
            const maxItemsPerColumn = 20;
            let y = 40; // Initial vertical position

            const startIndex = predefinedNames.indexOf(startName) + 1; // Start after the given name
            if (startIndex <= 0 || startIndex >= predefinedNames.length) {
                pdf.setFontSize(12);
                pdf.text('Starting name not found or no subsequent names in the list.', marginLeft, y);
            } else {
                // Calculate end index based on the counts
                const endIndex = Math.min(startIndex + countFirst + countThird + countFourth, predefinedNames.length);
                const names = predefinedNames.slice(startIndex, endIndex);

                // Determine names for each column
                let firstColumnNames = names.slice(0, countFirst);
                let secondColumnNames = [];
                let thirdColumnNames = names.slice(countFirst, countFirst + countThird);
                let fourthColumnNames = names.slice(countFirst + countThird, countFirst + countThird + countFourth);

                // Handle overflow from first to second column
                if (firstColumnNames.length > maxItemsPerColumn) {
                    secondColumnNames = firstColumnNames.splice(maxItemsPerColumn);
                }

                // Numbering starts from 1 and continues across all columns
                let currentNumber = 1;

                // First Column
                pdf.setFontSize(12);
                pdf.text('BankEmail', marginLeft, y); // Column label
                y += lineHeight;
                firstColumnNames.forEach((name, index) => {
                    pdf.text(`${currentNumber}. ${name}`, marginLeft, y);
                    y += lineHeight;
                    currentNumber++;
                });

                // Reset Y position and adjust for second column
                y = 40;
                pdf.setFontSize(12);
                pdf.text('BankEmail', marginMiddle1, y); // Column label
                y += lineHeight;
                secondColumnNames.forEach((name, index) => {
                    pdf.text(`${currentNumber}. ${name}`, marginMiddle1, y);
                    y += lineHeight;
                    currentNumber++;
                });

                // Reset Y position and adjust for third column
                y = 40;
                pdf.setFontSize(12);
                pdf.text('FU', marginMiddle2, y); // Column label
                y += lineHeight;
                thirdColumnNames.forEach((name, index) => {
                    pdf.text(`${currentNumber}. ${name}`, marginMiddle2, y);
                    y += lineHeight;
                    currentNumber++;
                });

                // Reset Y position and adjust for fourth column
                y = 40;
                pdf.setFontSize(12);
                pdf.text('soar', marginRight, y); // Column label
                y += lineHeight;
                fourthColumnNames.forEach((name, index) => {
                    pdf.text(`${currentNumber}. ${name}`, marginRight, y);
                    y += lineHeight;
                    currentNumber++;
                });

                // Add removed names section below the third column
                y = Math.max(y + lineHeight * 2, 150); // Ensure it starts below existing content
                pdf.setFontSize(16);
                pdf.text('Removed Names', marginMiddle2, y);
                y += lineHeight;
                pdf.setFontSize(12);
                removedNames.forEach((name, index) => {
                    pdf.text(`${index + 1}. ${name}`, marginMiddle2, y);
                    y += lineHeight;
                });
            }

            return pdf;
        }

        // Function to trigger the download of the PDF
        function downloadNamesList(startName, countFirst, countThird, countFourth, displayDate) {
            const pdf = generatePDFContent(startName, countFirst, countThird, countFourth, displayDate);
            pdf.save('names_list.pdf');
        }

        // Function to remove all occurrences of a specified name
        function removeName(nameToRemove) {
            predefinedNames = predefinedNames.filter(name => name !== nameToRemove);
            removedNames.push(nameToRemove); // Track the removed name
            updateRemovedNamesList(); // Update the UI list
        }

        // Function to update the removed names list in the UI
        function updateRemovedNamesList() {
            removedNamesList.innerHTML = ''; // Clear existing list
            removedNames.forEach(name => {
                const listItem = document.createElement('li');
                listItem.textContent = name;
                removedNamesList.appendChild(listItem);
            });
        }

        // Function to display notifications
        function showNotification(message, type) {
            const notification = document.createElement('div');
            notification.className = `alert ${type}`;
            notification.textContent = message;
            notificationContainer.appendChild(notification);
            setTimeout(() => notification.remove(), 5000);
        }

        // Handle display form submission
        displayForm.addEventListener('submit', function(event) {
            event.preventDefault(); // Prevent form submission
            
            const startName = document.getElementById('startName').value.trim();
            const numNamesFirst = parseInt(document.getElementById('numNamesFirst').value, 10);
            const numNamesThird = parseInt(document.getElementById('numNamesThird').value, 10);
            const numNamesFourth = parseInt(document.getElementById('numNamesFourth').value, 10);
            const displayDate = document.getElementById('displayDate').value;

            if (numNamesFirst < 0 || numNamesThird < 0 || numNamesFourth < 0) {
                showNotification('Please enter valid numbers.', 'error');
                return;
            }

            downloadNamesList(startName, numNamesFirst, numNamesThird, numNamesFourth, displayDate); // Trigger PDF download
        });

        // Handle remove name form submission
        removeForm.addEventListener('submit', function(event) {
            event.preventDefault(); // Prevent form submission
            
            const removeNameInput = document.getElementById('removeName');
            const nameToRemove = removeNameInput.value.trim();
            
            if (nameToRemove === '') return; // Don't proceed if the input is empty
            
            removeName(nameToRemove); // Remove name from predefined list

            // Notify user of successful removal
            showNotification(`Name "${nameToRemove}" removed from the list.`, '');

            removeNameInput.value = ''; // Clear the input field
        });

    </script>
</body>
</html>
